package simple.array;

/**
 * <a href="https://leetcode.cn/problems/height-checker/description/">1051. 高度检查器</a>
 * 学校打算为全体学生拍一张年度纪念照。根据要求，学生需要按照 非递减 的高度顺序排成一行。
 * 排序后的高度情况用整数数组 expected 表示，其中 expected[i] 是预计排在这一行中第 i 位的学生的高度（下标从 0 开始）。
 * 给你一个整数数组 heights ，表示 当前学生站位 的高度情况。heights[i] 是这一行中第 i 位学生的高度（下标从 0 开始）。
 * 返回满足 heights[i] != expected[i] 的 下标数量 。
 * 示例：
 *   输入：heights = [1,1,4,2,1,3]
 *   输出：3
 *   解释：
 *     高度：[1,1,4,2,1,3]
 *     预期：[1,1,1,2,3,4]
 *     下标 2 、4 、5 处的学生高度不匹配。
 * 示例 2：
 *   输入：heights = [5,1,2,3,4]
 *   输出：5
 *   解释：
 *     高度：[5,1,2,3,4]
 *     预期：[1,2,3,4,5]
 *     所有下标的对应学生高度都不匹配。
 * 示例 3：
 *   输入：heights = [1,2,3,4,5]
 *   输出：0
 *   解释：
 *     高度：[1,2,3,4,5]
 *     预期：[1,2,3,4,5]
 *     所有下标的对应学生高度都匹配。
 * 提示：
 *   1 <= heights.length <= 100
 *   1 <= heights[i] <= 100
 * @author 刘学松
 * @date 2023-07-07 15:08
 */
public class 高度检查器 {
    public int heightChecker(int[] heights) {
        int[] bucket = new int[101];
        for (int height : heights) {
            ++bucket[height];
        }
        int count = 0;
        int start = 1;
        for (int height : heights) {
            while (bucket[start] == 0) {
                ++start;
            }
            if (start != height) {
                ++count;
            }
            --bucket[start];
        }
        return count;
    }
}
